iT邦幫忙

2024 iThome 鐵人賽

DAY 6
0
Python

利用Python完成自動化測試專案系列 第 6

D6 強大的定位功能-XPATH

  • 分享至 

  • xImage
  •  

這次要介紹的是昨天在最後賣關子的 XPATH定位功能。

如何使用XPATH

昨天提到不用複製貼上的方法主要是因為它複製的是絕對路徑,只要前面的節點結構有動到就不能用了。
而第二種方法就是用相對路徑來尋找元素,等等會先實作幾個例子,再講解 XPATH 的寫法。

實際演練

以iT邦幫忙頁面為例,如果要找"技術問答"這個按鈕有幾種方式
https://ithelp.ithome.com.tw/upload/images/20240920/20169358nKMsXI8e80.jpg
https://ithelp.ithome.com.tw/upload/images/20240920/20169358BxJ4TgXD0L.jpg

class

可以用class名稱找

//a[@class = 'menu__item-link  menu__item-link--pl']

要確認有沒有定位到元素,只要在網頁開發工具下 ctrl+f,用下面的搜尋欄尋找即可。

https://ithelp.ithome.com.tw/upload/images/20240920/20169358yNnGlMjQTM.jpg
右下方顯示1/1,代表定位成功

不過這個 class的名稱有點太長,若是在確認不會跟其他 class 重複的情況下,可以只抓部分的文字名稱,具體方法如下:

//a[contains(@class, 'menu__item-link--pl')]

text()

以這個元素為例,同樣也可以用文字的方式來抓這個 element。這個時候就會用到text(),它比較特殊的部分是它不是屬性所以前面不用加'@'

//a[text()='技術問答']

上文中提到的 contains 在 text 裡也可以使用,以"聊天室"為例

//a[contains(text(), '聊天')]

and

以剛剛提到的 contains 在 text 的運用,尋找"iT 徵才"

//a[contains(text(), '徵才')]

會發現找到3個元素,而我們只想找到 iT 徵才這個元素,這個時候就可以用 and。

https://ithelp.ithome.com.tw/upload/images/20240920/20169358XvX5jYmop8.jpg
觀察這三個元素

<a href="https://ithelp.ithome.com.tw/articles?tab=job" class="menu__item-link  hidden-xs">iT 徵才</a>

上面這個是目標元素,下面兩個是我們要排除的

<a href="https://ithelp.ithome.com.tw/articles/create?group=job">徵才</a>
<a href="https://ithelp.ithome.com.tw/articles/create?group=job">徵才</a>

可以發現其他兩個元素只有連結跟文字而已,這個時候我們就可以使用 and ,把 class的條件一併包進來。

//a[contains(text(), '徵才') and contains(@class, 'hidden-xs')]

可以看到成功定位出我們要的元素。
https://ithelp.ithome.com.tw/upload/images/20240920/20169358u61gSYfUtR.jpg

index 定位

現在以技術問答的文章為例
https://ithelp.ithome.com.tw/upload/images/20240920/201693580okQXm1yyE.jpg
如果要選擇第一個文章,或是要選擇特定的文章,就可以用 index 的方式定位。

透過網頁開發工具,可以觀察到每一篇文章的元素都一樣
https://ithelp.ithome.com.tw/upload/images/20240920/20169358nuEF6qsS48.jpg
以class定位,可以把所有文章都定位到。

//div[@class='qa-list']

https://ithelp.ithome.com.tw/upload/images/20240920/20169358ZrkiDxjPLr.jpg
如果要定位到第一個文章,可以用以下的作法

(//div[@class='qa-list'])[1]

https://ithelp.ithome.com.tw/upload/images/20240920/20169358qaENKgzpn6.jpg
如果要定位的是第十個文章

(//div[@class='qa-list'])[10]

https://ithelp.ithome.com.tw/upload/images/20240920/20169358u3SGoiswxI.jpg
這邊要注意的是 index 的頭是由1開始,跟前幾天提到的 for 迴圈或其他程式語言的 index 從0開始不一樣。

XPATH 寫法

從上面幾個例子可以看出, XPATH 基本上是由標籤名稱與標籤內的屬性和屬性的值來尋找,通常以目標元素那一層的標籤開始定位,整體寫法可以整理成如下:

//標籤名稱[@屬性='屬性的值']

總結

今天提到了基本的 XPATH 定位方法,其實還有更進階的查找方法,後面如果會遇到再另行補充。
明天預計會介紹Selenium的各個網頁的基本操作(點擊、輸入等)。


上一篇
D5 locator介紹
下一篇
D7 與網頁互動
系列文
利用Python完成自動化測試專案12
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

尚未有邦友留言

立即登入留言